

Intel<sup>®</sup> Firmware Support Package (Intel<sup>®</sup> FSP) for Intel Atom<sup>®</sup> x6000E Series, and Intel<sup>®</sup> Pentium<sup>®</sup> and Celeron<sup>®</sup> N and J Series Processors (Formerly known as Elkhart Lake), MR1

**Release Notes - MR1** 

August 2021

Document number: 646960



You may not use or facilitate the use of this document in connection with any infringement or other legal analysis concerning Intel products described herein. You agree to grant Intel a non-exclusive, royalty-free license to any patent claim thereafter drafted which includes subject matter disclosed herein

No license (express or implied, by estoppel or otherwise) to any intellectual property rights is granted by this document.

Intel disclaims all express and implied warranties, including without limitation, the implied warranties of merchantability, fitness for a particular purpose, and non-infringement, as well as any warranty arising from course of performance, course of dealing, or usage in trade.

All information provided here is subject to change without notice. Contact your Intel representative to obtain the latest Intel product specifications and roadmaps.

The products described may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

Copies of documents which have an order number and are referenced in this document may be obtained by calling 1-800-548-4725 or by visiting: <a href="http://www.intel.com/design/literature.htm">http://www.intel.com/design/literature.htm</a>

Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Learn more at <a href="http://www.intel.com/">http://www.intel.com/</a> or from the OEM or retailer.

Intel, Intel Atom, and the Intel logo are trademarks of Intel Corporation in the U.S. and/or other countries.

\*Other names and brands may be claimed as the property of others.

Copyright @ 2021, Intel Corporation. All rights reserved.



## **Contents**

| 1.0      | Intro  | duction                                       | 5  |
|----------|--------|-----------------------------------------------|----|
|          | 1.1    | Terminology                                   | 5  |
|          | 1.2    | Related Documentation, Tools, and Packages    |    |
|          | 1.3    | Intended Audience                             |    |
|          | 1.4    | Customer Support                              | 6  |
| 2.0      | New i  | in This Release                               | 7  |
|          | 2.1    | PV Features                                   | 7  |
| 3.0      | Fixed  | Issues                                        | 8  |
| 4.0      | Limita | ations                                        | 9  |
|          | 4.1    | Current Release                               |    |
| 5.0      | Know   | /n lssues                                     | 10 |
|          | 5.1    | Current Release                               | 10 |
| 6.0      | Split  | FSP image into individual FSP-T/M/S component | 11 |
| 7.0      | Wher   | e to Find the Release                         | 12 |
| 8.0      | Relea  | Release Content                               |    |
| 9.0      | Hardy  | ware and Software Compatibility               | 14 |
|          | 9.1    | Supported Hardware                            | 14 |
|          | 9.2    | Supported Bootloaders                         | 14 |
| 10.0     | Sourc  | ce code level FSP UPD values configuration    | 15 |
|          | 10.1   | Coreboot                                      | 15 |
|          | 10.2   | Slim Bootloader                               | 16 |
| Tal      | oles   |                                               |    |
| Table    | e 1.   | Platform Software Component Information       | 5  |
| Table    | e 2.   | Terminology                                   |    |
| Table    | e 3.   | Related Documentation, Tools, and Packages    |    |
| Table 4. |        | Operating System/Boot Loader Support          | 14 |



# **Revision History**

These are the main releases of Intel® Firmware Support Package (Intel® FSP) for Intel® Soc processor Code-Named Elkhart Lake.

| Date           | Revision  | Description                                       |
|----------------|-----------|---------------------------------------------------|
| April 2020     | Alpha (3) | Initial Release (Elkhart Lake label v2115_00_423) |
| September 2020 | Beta (2)  | Beta release (Elkhart Lake label v2341_05_33)     |
| October 2020   | Beta (3)  | Beta 3 release (ElkhartLake_Daily2411_00_215)     |
| December 2020  | Beta (4)  | Beta 4 release (ElkhartLake_Label2463_00_122)     |
| March 2021     | PV        | PV Release (ElkhartLake_Label3092_03_101)         |
| March 2021     | Fusa PV   | PV Release (ElkhartLake_Label3125_02_104)         |
| April 2021     | PR1       | PR1 Release (ElkhartLake_Label3162_01_105)        |
| August 2021    | MR1       | MR1 Release (ElkhartLake_Label3273_04_122)        |



## 1.0 Introduction

This package contains required binary image(s) and collateral for the Intel® Firmware Support Package (Intel® FSP) for Intel® Soc processor code-named Elkhart Lake.

Compliant with FSP 2.1 External Architecture Specification.

This document provides system requirements, installation instructions, issues and limitations, and legal information.

To learn more about this product, see:

- New and previously new features listed in <u>Section 2.0, New in This Release</u>.
- Reference documentation listed in <u>Section 1.2, Related Documentation, Tools, and Packages</u>.

The following table lists the relevant platform software components used during development and validation of this release.

#### **Table 1. Platform Software Component Information**

Please use the correct microcode when integrating Intel® FSP. Any processor that does not have the correct microcode update loaded is considered to be operating out of specification. See the relevant bootloader's release notes for more details regarding microcode loading.

| Supported Silicon Stepping | Microcode Version   |
|----------------------------|---------------------|
| Bx                         | m_01_90661_00000014 |

## 1.1 Terminology

The following terms are used in this document.

#### Table 2. Terminology

| Term | Description                       |
|------|-----------------------------------|
| API  | Application Programming Interface |
| BSF  | Binary Settings File              |
| ВСТ  | Binary Configuration Tool         |
| CRB  | Customer Reference Board          |



| Term       | Description                     |
|------------|---------------------------------|
| Intel® EDC | Intel® Embedded Design Center   |
| Intel® FSP | Intel® Firmware Support Package |
| SoC        | System on Chip                  |

### 1.2 Related Documentation, Tools, and Packages

#### Table 3. Related Documentation, Tools, and Packages

| Document                                                                                       | Location                                                 |
|------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| ElkhartLake_FSP_Integration_Guide.pdf                                                          | Available in this release package                        |
| Intel® Binary Configuration Tool for Intel® Firmware Support<br>Package                        | www.intel.com/fsp                                        |
| Intel® Firmware Support Package (Intel® FSP) External Architecture<br>Specification (EAS) v2.1 | https://cdrdv2.intel.com/<br>v1/dl/getContent/61178<br>6 |

#### 1.3 Intended Audience

The intended audience is platform and system developers who intend to use an Intel® FSP-based boot loader for the firmware solution for their overall design based on the Intel® SOC processor code-named Elkhart Lake. This group includes, but is not limited to, system BIOS developers, boot loader developers, and system integrators.

## 1.4 Customer Support

Intel offers support for this software at the API level only, defined in the Intel® FSP Integration Guide and reference manuals listed in <u>Section 1.2, Related Documentation</u>, <u>Tools</u>, <u>and Packages</u>.

For technical support, please raise IPS (Intel® Premier Support) at <a href="https://intel.my.salesforce.com/">https://intel.my.salesforce.com/</a>



# 2.0 New in This Release

#### 2.1 MR1 Features

• Adopting Elkhart Lake IAFW external release ElkhartLake Label 3273\_04\_122



# 3.0 Fixed Issues

The following list contains the fixed issues in this release:

• None.



# 4.0 Limitations

## 4.1 Current Release

• Default max C-state supported: C9



# 5.0 Known Issues

#### **5.1** Current Release

• The max 4K option of "DDR Frequency Limit" in current FSP UPD was not shown



# 6.0 Split FSP image into individual FSP-T/M/S component

FSP 2.1 image can be split to 3 individual components using the SplitFspBin.py script in release package. For further details on splitting and integrating FSP, please refer the relevant bootloader's release notes.

#### Rebase address:

Bootloader will rebase and relocate FSP binary dynamically, so the base address is not hardcoded with the default base address and location. Once configure the FSP binary as XIP, Bootloader can decide where the binary will be placed in the core boot's CBFS or SBL's Fv and will take care of rebasing it during build.



## 7.0 Where to Find the Release

The FSP package can be found at:

https://github.com/intel/FSP/tree/master/ElkhartLakeFspBinPkg/

Or from: the *Elkhart Lake* Firmware Best Known Configuration (BKC) searchable at Intel<sup>®</sup> Resource & Design Center (RDC) Software Kits:

https://www.intel.com/content/www/us/en/secure/design/confidential/software-kits/view-all.html?s=Newest



## 8.0 Release Content

This release contains:

- Intel® FSP Integration Guide
- Intel® FSP Binary
- Binary Settings File (BSF)
- Release Notes



# 9.0 Hardware and Software Compatibility

## 9.1 Supported Hardware

This Intel® Firmware Support Package (Intel® FSP) release is specifically targeted for Intel Atom® x6000E series, and Intel® Pentium® and Celeron® N and J Series processors (Formerly known as Elkhart Lake).

### 9.2 Supported Bootloaders

This release can be installed on either a Windows\* or a Linux\* system. However, the Intel® FSP binary itself can be used with any software development environment to generate a complete boot loader solution.

The software in this release has been validated on customer reference boards (CRBs) with the boot loader and operating systems listed in the following table.

#### Table 4. Operating System/Boot Loader Support

| Product Family                                   | Boot Loader                                | Operating System             |
|--------------------------------------------------|--------------------------------------------|------------------------------|
| Intel® Soc Processor code-<br>named Elkhart Lake | EHL SBL* with the<br>UEFI/OsLoader payload | Yocto Project*<br>Windows 10 |
| Intel® Soc Processor code-<br>named Elkhart Lake | coreboot* with the UEFI payload            | Yocto Project*<br>Windows 10 |



# 10.0 Source code level FSP UPD values configuration

FSP UPD settings can be configured from respective bootloaders from source code level. Details provided here for modifying default values provided by FSP UPDs in supported bootloaders as mentioned in Section 9.2.

Here are 2 potions of FSP that can be changed from bootloaders:

| FSP potion | FSP Headers file (UPD reference codes) |
|------------|----------------------------------------|
| FSP-M      | Include/ <b>FspmUpd.h</b>              |
| FSP-S      | Include/ <b>FspsUpd.h</b>              |

The respective UPDs can be found inside the respective FSP headers file.

#### 10.1 coreboot

To modify the default FSP UPD values in coreboot, please navigate to respective files:

| FSP potion to change | Source code                                                 |
|----------------------|-------------------------------------------------------------|
| FSP-M                | src\soc\intel\elkhartlake_dev\romstage\ <b>fsp_params.c</b> |
| FSP-S                | src\soc\intel\elkhartlake_dev\ <b>fsp_params.c</b>          |

Here are the examples to change the UPD values: -

1. For UPDs that have been exposed in the source code, just change the value (highlighted in yellow) to the desired value:

```
/* Vt-D config */
m_cfg->VtdDisable = 0;
```

2. For UPDs that have not been exposed in coreboot source code, just insert code as shown below:

| FSP-M (insert code below in this function: void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd, uint32_t version)) | FSP-S (insert code below in this function: void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)) |
|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| m_cfg-> { <mark>UPD</mark> } = { <mark>desired value</mark> }                                                         | params-> { <mark>UPD</mark> } = { <mark>desired value</mark> }                                       |



#### 10.2 Slim Bootloader

To modify the default FSP UPD values in slim bootloader, please navigate to respective files:

| FSP potion<br>to change | Source code                                                                                 |
|-------------------------|---------------------------------------------------------------------------------------------|
| FSP-M                   | SblInternal\Platform\ElkhartlakeBoardPkg\Library\Stage1BBoardInitLib\ Stage1BBoardInitLib.c |
| FSP-S                   | SblInternal\Platform\ElkhartlakeBoardPkg\Library\Stage2BoardInitLib\ Stage2BoardInitLib.c   |

Here are the examples to change the UPD values: -

3. For UPDs that have been exposed in the source code, just change the value (highlighted in yellow) to the desired value:

/\* Vt-D config \*/

Fspmcfg->VtdDisable = 0;

4. For UPDs that have not been exposed in slimboot source code, just insert code as shown below:

| FSP-M (insert code below in this                                | FSP-S (insert code below in this                                |
|-----------------------------------------------------------------|-----------------------------------------------------------------|
| function: <a href="VOID UpdateFspConfig">VOID *FspmUpdPtr</a> ) | function: <a href="VOID UpdateFspConfig">VOID *FspsUpdPtr</a> ) |
| Fspmcfg-> {UPD} = {desired value}                               | Fspscfg-> { <mark>UPD</mark> } = { <mark>desired value</mark> } |